home *** CD-ROM | disk | FTP | other *** search
/ Skunkware 5 / Skunkware 5.iso / tls / tls012.ltr < prev    next >
Text File  |  1994-09-02  |  22KB  |  492 lines

  1. This is a recent rev of Warren Tucker's excellent monitor for UNIX.
  2. This one compiles and runs on SCO UNIX Release 3.2 Version 4, and
  3. also on Open Desktop 2.0 and later.  The version number is approximately
  4. 2.70.
  5.  
  6. Below are the README files from the previous version, with a
  7. teeny bit of editing. -dionj@sco.com
  8.  
  9. ======================================================================
  10. u386mon 2.70 README - Tue Apr 07 14:43:08 EDT 1992
  11. ==================================================
  12.  
  13. This is u386mon 2.70, a "performance" monitor, ostensibly for SCO UNIX
  14. V/386 and ISC 386/ix, although it has been ported to a 68k VME System V
  15. Release 3.1 platform and to ISC 1.0.x and to the Tandem Integrity S2
  16. (both S5R3.0-ish).  Also, a renice is included as an example of
  17. alternate uses of the kmem/mem/swap utility objects.
  18.  
  19. U386mon has been tested on SCO 3.2.x and ODT and ISC 1.0.x, 2.0.x and
  20. 2.2.x, Tandem Integrity S2 NonStop-UX and at least one MC68000 VME-based
  21. Sys V Rel 3.1 system.
  22.  
  23. These may work with other UNIX System 5 Release 3.x systems with a
  24. little work.  XENIX systems have greatly different kernel
  25. implementations and use xlist instead of nlist.  These programs will not
  26. work there; sorry.  Someone reported he was working on a port to XENIX,
  27. but jct!jct's mon386 is great (posted to comp.unix.xenix on 11 Jul 89 in
  28. 9 parts, starting with Message-ID: <278@jct.UUCP>).
  29.  
  30. U386mon requires terminfo style curses and will use color if you have
  31. it.  It works best with a 43 line (or greater) screen, but will work
  32. with a 25 line screen with some limitations.  It works very well on SCO
  33. ODT, Metro Link X11R4 and ISC xterms.  On a Wyuse 60, the SCO color
  34. curses does some interesting attribute mappings.
  35.  
  36. On a 20Mhz Compaq 386 running SCO UNIX 3.2.0, u386mon on a 43-line VGA,
  37. with a two second update interval, appears to consume 3 to 5% of the CPU
  38. when in the "main" display and about 7 to 11% when displaying process
  39. status (NPROC, v.v_proc == 100).  This is a bit expensive, but the job
  40. is sorta hard: according to prof(1)/prof(CP), 50% of the time is spent
  41. in curses.  Of course, on the Tandem Integrity S2 (a MIPS based
  42. machine), these figures were MUCH, MUCH lower :-).  On a 486 33 MHz
  43. machine, I get very much lower figures as well.  In fact, the guy was so
  44. fast we found a divide by zero possibility where u386mon could run a
  45. whole cycle without ticking the clocks, getting zero total cpu ticks
  46. over the cycle.
  47.  
  48. Acknowledgments
  49. ===============
  50.  
  51. Thanks to martin@hppcmart.grenoble.hp.com (Martin Croome), who gets
  52. complete credit for the nice SCO STREAMS, table and winchester statistics.
  53. Neils Baggesen ported/tested them on S5R3.1.
  54.  
  55. Thanks to peter@radig.de (Peter Radig), dug@kd4nc (Doug Drye),
  56. jdc@uudell.dell.com (Jeremy Chatfield), andy@rbdc (Andy Pitts),
  57. trb@ima.ima.isc.com (Andrew Tannenbaum) for the help with ISC 386/ix.
  58.  
  59. Thanks to nba@sysware.dk (Neils Baggesen) and allbery@ncoast.org
  60. (Brandon Allbery) for the System V Release 3.1 work.
  61.  
  62. Thanks to jmd@tdmsou (emory!n4hgf!tdmsou!jmd, John Dashner) for the Tandem
  63. S2 work.
  64.  
  65. Thanks to Dion Johnson <dionj@sco.com>, Bob Tinsman <bobti@sco.com>
  66. and David Gurr <davidgu@sco.com> for encouragement to keep work going.
  67.  
  68. If I missed mentioning some work you did, please accept my apology and
  69. remind me.
  70.  
  71. Yellow Brick Road
  72. =================
  73.  
  74. Read through this and you will finally reach "How to get going" below.
  75.  
  76. Sample output (somewhat obsolete)
  77. =================================
  78. (with 43-line screen; a 25 line screen will be missing Var/Bootinfo/Tune/Proc
  79. on the 'main' display)
  80.  
  81.  u386mon 2.11/SCO 3.2 - n4hgf                                 04:39:36 wht@n4hgf
  82. ---- CPU --- tot usr ker brk ---------------------------------------------------
  83.  Instant %    93  54  39   0 uuuuuuuuuuuuuuuuuuuuuuuuuuukkkkkkkkkkkkkkkkkkk     
  84.  5 Sec Avg %  87  26  61   0 uuuuuuuuuuuuukkkkkkkkkkkkkkkkkkkkkkkkkkkkkk        
  85. 10 Sec Avg %  89  45  44   0 uuuuuuuuuuuuuuuuuuuuuukkkkkkkkkkkkkkkkkkkkkk       
  86. ---- Wait -- tot  io pio swp -- (% of real time) -------------------------------
  87.  Instant %     5   5   0   0 ii                                                 
  88.  5 Sec Avg %  12  12   0   0 iiiiii                                             
  89. 10 Sec Avg %   9   9   0   0 iiii                                               
  90. ---- Sysinfo/Minfo --- (last  1000 msec activity) ------------------------------
  91. bread          5  readch    60416  pswitch    21   vfault    1    unmodsw   0   
  92. bwrite         9  writch     2507  syscall   261   demand    1    unmodfl   0   
  93. lread        331  rawch         2  sysread   100   pfault   15    psoutok   0   
  94. lwrite        42  canch         0  syswrit     4   cw        0    psinfai   0   
  95. phread         0  outch      2508  sysfork     1   steal    15    psinok    0   
  96. phwrite        0  msg           0  sysexec     0   frdpgs    0    rsout     0   
  97. swapin         0  sema          0                  vfpg      0    rsin      0   
  98. swapout        0  maxmem    5724k  runque      0   sfpg      0                  
  99. bswapin        0  frmem     3284k  runocc      0   vspg      0    pages on      
  100. bswapout       0  mem used    43%  swpque      0   sspg      0    swap      0   
  101. iget          72  nswap    10000k  swpocc      0   pnpfault  0    cache     0   
  102. namei         71  frswp    10000k                  wrtfault  0    file      0   
  103. dirblk        92  swp used     0%                                               
  104.                                                                                 
  105.                                                                                 
  106.                                                                                 
  107. -- Var ---------  -- Bootinfo ----------   -- Tune ---------  -- Proc ---       
  108. v_autoup      10  basemem      640k        t_ageintvl      9  sleep    22       
  109. v_buf        600  extmem      6144k        t_bdflushr      1  run       1       
  110. v_clist      200  bflags   00000000        t_gpgshi       40  zombie    0       
  111. v_file       200  memory available         t_gpgslo       25  stop      0       
  112. v_hbuf        64  00000000 000a0000        t_gpgsmsk   0x420  idle      0       
  113. v_inode      200  00100000 00600000        t_maxfc         1  onproc    1       
  114. v_maxpmem      0  00f40000 00060000 NODM   t_maxsc         1  xbrk      0       
  115. v_maxup       60  memory used              t_maxumem    2560  total    24       
  116. v_mount        5  00000000 00004000 RSVD   t_minarmem     25  in mem   24       
  117. v_pbuf        20  006bb000 00037000 KBSS   t_minasmem     25                    
  118. v_proc       100  006f2000 0000e000 KDTA                                        
  119. v_region     210  00fa9000 00057000 KTXT                                        
  120. v_vhndfrac    16                                                                
  121.  
  122. The main display
  123. ================
  124.  
  125. A brief description of reported information:
  126.  
  127. 0.  The '+' and '-' command adds or subtracts one second from the
  128.     update interval.  The value at startup is 2 seconds, the
  129.     range 1 to 4.  Below, the terms "x1", "x5" and "x10" mean
  130.     "interval X 1", "interval times 5" and "interval times 10,"
  131.     respectively.
  132.  
  133.     You can determine the update interval by looking at the top
  134.     CPU histogram, labeled "Instant" for 1, "X sec" for 2-4 second
  135.     intervals.
  136.  
  137.     On some *fast* systems, values may be too large in 3 and 4
  138.     second intervals and corrupt the display.  But the, you have
  139.     the extra CPU to run it more often :-).
  140.  
  141. 1.  The CPU utilization is shown with smoothing of x1 ("instant" if
  142.     the update interval is 1 second), x5 and x10 seconds.  Total
  143.     CPU usage is shown, with user, kernel and "break" subdivided.
  144.     Most performance utilities (vmstat) lump kernel (CPU_KERNEL)
  145.     and wait (CPU_WAIT) times together as kernel time.  u386mon
  146.     considers CPU_WAIT time as idle (the CPU could have been
  147.     doing something if an otherwise ready process wasn't waited).
  148.  
  149.     On a color display, total cpu utilization is displayed in
  150.     green if the cpu utilization is below 70%, yellow if utilization
  151.     is between 70% and 89% and red if 90% or above.
  152.  
  153. 2.  The Wait display shows the x1, x5 and x10 second smoothed
  154.     percentages of real time no process could be run because
  155.     otherwise ready to run processes were waiting on logical,
  156.     swap or physical I/O.
  157.  
  158.     On a color display, total wait time is displayed in green if
  159.     it is below 30%, yellow if utilization is between 30% and 49%
  160.     and red if 50% or above.
  161.  
  162. 3.  Sysinfo/Minfo display shows, generally, the number of events
  163.     for a measured value since the last display update.  For
  164.     example, runque shows the number of times a process was
  165.     placed on the run queue.  An exception is the memory and swap
  166.     space fields: These numbers reflect absolute current
  167.     utilization over the period shown in the "last XXXXX msec"
  168.     value in the banner.  Periods of 4000 milliseconds are shown
  169.     in red, 1500 to 3990 milliseconds in blue and less than 1500
  170.     milliseconds in the normal banner color.
  171.  
  172.     My guess as to the meaning of the sysinfo and minfo values is
  173.     in the file EXPLAIN.  I am not familiar with the meanings of
  174.     all the items, having looked through the header files, sar
  175.     man pages and the other UNIX hacker-ganda I could find.
  176.     Comments are appreciated.
  177.  
  178. 4.  If you run u386mon on a 43 line display, extra information is displayed
  179.     on the bottom of the screen (from the struct var v, bootinfo
  180.     and proc kernel databases).
  181.  
  182.     On a 24/25-line screen, the 'e' command accesses the Var/Bootinfo/
  183.     Tune/Proc display, overlaying the Sysinfo/Minfo display.
  184.     Using 'm' returns you to the main display.
  185.  
  186.     Bootinfo will be missing from version running on platforms which
  187.     do not support it.
  188.  
  189. 5.  On a color display, static numeric values, such as maxmem appear
  190.     in blue (the same color as screen literals/labels).  Dynamic
  191.     numeric values are displayed in green, with the exception of
  192.     total cpu and wait percentages, which appear in light green,
  193.     red or yellow.
  194.  
  195. 6.  An "INEXACT" indication on the top line means that u386mon was
  196.     not scheduled quickly enough to capture accurate 1 second (nominal)
  197.     values.  Continued INEXACT indication suggests the x5 and x10
  198.     second smoothed values are also wrong.
  199.  
  200.     An "INVALID" indication means u386mon was scheduled 3 or more
  201.     seconds late; all percentage isplays are now suspect.
  202.  
  203. 7.  IN GENERAL, if you see any red characters on the display,
  204.     immediately take grain of salt. If you have no color screen
  205.     and still see red, add tequila to salt.
  206.  
  207. 8.  If you are running as root, you may use the -l switch or the
  208.     'l' command to lock u386mon into memory.  If you do this, PLOCK
  209.     will appear at the top of the screen to remind you of this hoggy
  210.     behavior.  The u386mon process will not be listed in a process
  211.     status display since SSYS (locked, resident) processes are not
  212.     shown.
  213.  
  214. 9.  The ISC bootinfo field will have different information due to
  215.     different porting by ISC and SCO.
  216.  
  217. Process Status Display
  218. ======================
  219.  
  220. 1.  Pressing 'p' causes a process status display of sorts to be
  221.     shown, overlaying Sysinfo/Minfo on a 25 line screen or
  222.     Var/Bootinfo/Tune/Proc on a 43 line screen.  On a 43 line screen, 'P'
  223.     causes a larger ps display to be shown, overlaying Sysinfo/Minfo and
  224.     Var/Bootinfo/Tune/Proc.
  225.  
  226.     Sample output:
  227.  
  228. S     USER   PID  CPU PRI NI  UCPU   SCPU  SIZE TTY CMD
  229. s     root    148   0  26 20   0:00   0:05  108  ?? /etc/cron
  230. s      wht  14946   2  39 20   0:02   0:11  224  05 TMR 01000a12
  231. s      wht  14947   2  39 20   0:02   0:11  220  05 TMR 01011101
  232. s      wht  14950   0  27 20   0:00   0:02  228  05 IP 01000a12
  233. s      wht  14951   1  27 20   0:00   0:02  224  05 IP 01011101
  234. s      wht  14952   0  27 20   0:01   0:02  228  05 TP4 01000a12
  235. s      wht  14953   1  27 20   0:01   0:03  224  05 TP4 01011101
  236. s      wht  14957   0  27 20   0:00   0:04  200  05 smpad.x
  237. s      wht  14960   1  27 20   0:00   0:04  204  05 mmpad.x
  238. s     root  15044   0  28 20   0:01   0:01  296  12 vi README
  239. s     uucp  15053   0  30 26   0:00   0:00  696  ?? /usr/lib/uucp/uusched
  240. s     uucp  15055   0  30 26   0:00   0:00  748  ?? UUCICO -r1 -sgatech
  241. s     uucp  15060   0  28 26   0:00   0:00  768  ?? dialTBIT tty2E 2222222UC 192
  242.  
  243.     NOTES
  244.     a.   S - two character status
  245.             1st character - process status
  246.                s - sleeping
  247.                R - ready to run (might be running if u386mon were not)
  248.                z - zombie
  249.                d - stopped by debugger
  250.                i - idle (in creation?)
  251.                p - running on processor (on single CPU systems, only u386mon
  252.                    will show this)
  253.                x - XBREAK - process growing or shrinking
  254.             2nd character - process swap status
  255.                S - process is swapped
  256.                blank - process is in memory
  257.  
  258.     b.  If the process is running with setuid, a '#' appears to
  259.         the right of the username.
  260.  
  261.     c.  On color systems, processes ready to run are shown in yellow
  262.         unless they are ready, but swapped out, in which case they
  263.         are shown in red.
  264.  
  265. 3.  Since a limited space is available for displaying process
  266.     status, particularly on a 25-line screen, a selective elimination
  267.     algorithm is used to whittle the list when insufficient room
  268.     is available.  init (pid 1) and system/resident (SSYS)
  269.     processes are never displayed.  When a display cycle is to begin
  270.     and there is not room for all of the processes to be shown,
  271.     processes are eliminated in the following order:
  272.  
  273.     a. 'getty', 'uugetty', 'sh', 'csh', and 'ksh'
  274.     b. swapped and zombie processes
  275.     c. no cpu processes (no cpu time during last cycle)
  276.     d. sleeping processes
  277.  
  278.     If there is still insufficient room, an indication to the effect
  279.     is displayed (tough cookies).
  280.  
  281. Disk (Winchester) display
  282. =========================
  283.  
  284. This display shows each disk and diskette device known to the system
  285. and performance statistics for each.  Currently, the information is
  286. available only on SCO systems.  The percentages will be inaccurate for
  287. one or two display cycles after the 'w' (winchester) selection
  288. becomes active.  Further updates may be inaccurate due to either
  289. noisy kernel data, data capture latency, our having to guess a
  290. lot, or any combination of the above.
  291.  
  292. STREAMS (Net) display
  293. =====================
  294.  
  295. This display shows STREAMS queues and buffers utilization a bit
  296. faster and more dynamically than /etc/crash strstat!  Currently,
  297. the information is available only on SCO systems.
  298.  
  299. Table Display
  300. =============
  301.  
  302. The current and maximum occupancy of various kernel tables are displayed.
  303. This may not be enabled for all systems (I couldn't test Everywhere!).
  304.  
  305. Sio display
  306. ===========
  307.  
  308. The experimental, "undocumented" sio display is a stab at tty I/O
  309. monitoring for SCO only. It will misbehave harmlessly if you do
  310. not have the sio driver installed (i.e., FAS in use).
  311.  
  312. A $0.0002 tour: why nlsym and /unix.nlsym?
  313. ==========================================
  314.  
  315. Access to kernel (/dev/kmem) and physical (/dev/mem) memory and
  316. swap (/dev/swap) is required for u386mon to do its thing.
  317. To find kmem addresses of interest, an nlist(S) call must be made
  318. against /unix.  This can be quite expensive.
  319.  
  320. The 'nlist' procedure is performed by a separate program (nlsym)
  321. and the resulting nlist structure array is stored in /unix.nlsym.
  322. u386mon thus may obtain nlist information rapidly without nlist(S) each
  323. time it is executed.  Also stored in /unix.nlsym is a stat structure of
  324. /unix at the time of nlsym execution.  A unique word is stored at the
  325. end of the file in case /unix.nlsym's nlist structure is expanded for
  326. other applications.  The u386mon program reads /unix.nlsym by means
  327. of facilities in libnlsym.c.  If the stat structure in /unix.nlsym
  328. does not match a dynamic stat of /unix or if the unique word does
  329. not match, the nlist information is not trusted and u386mon prompts
  330. the user to run (or have run) the nlsym program to update /unix.nlsym.
  331.  
  332. Many symbols are nlist'ed by nlsym which are not used by u386mon.
  333. You may find other uses for libnlsym/libkmem which make use of them.
  334.  
  335. How to get going
  336. ================
  337.  
  338. 1.  Copy the appropriate Make. file to Makefile, depending on
  339.     your type of system.  It has been a while since I have had
  340.     good reports on the various OSs other than SCO UNIX, so good luck.
  341.  
  342.     Make.dell           DELL System V (ISC derived)
  343.     Make.isc1           ISC 1.x
  344.     Make.isc2           ISC 2.x
  345.     Make.isc2.gcc       ISC 2.x with gcc (untested)
  346.     Make.s2             Tandem Integrity S2 Non-Stop UX
  347.     Make.sVr31          Various System 5 Release 3.1 (good luck)
  348.     Make.sco            SCO UNIX 3.2, 3.2.1, 3.2r2, ODT 1.x
  349.     Make.sco.gcc        same with gcc 1.39
  350.  
  351. 2.  Edit Makefile to change BINDIR to match your local requirements.
  352.     If you have a kernel that knows about MERGE386 as with SCO ODT,
  353.     add -DMERGE386 to CFLAGS. Likewise, if you have VPIX, add -DVPIX.
  354.     You may need to add -Dm68k for a MC68000 system if your
  355.     compiler does not (This may sound like an odd statement for a
  356.     program with 386 in the name, but we are broadening our territory :->).
  357.  
  358. 3.  make all.  Please report compile errors to me.  You shouldn't
  359.     get any on SCO 3.2.x or ISC 2.x.x for any "recent" or current versions.
  360.  
  361. 3a. Note: Don't worry, if on SCO makes, you see warnings on many modules'
  362.     compilation similar to the following:
  363.  
  364.                  cc -nointl -c -Octl -CSON -DLINT_ARGS u386mon.c
  365.         u386mon.c
  366.         /usr/include/tinfo.h(442) : warning C4005: 'box' : redefinition
  367.         /usr/include/tinfo.h(443) : warning C4005: 'newterm' : redefinition
  368.  
  369.     This is confusion on part of tinfo.h resulting from our use of
  370.     some valuable speedup macros built into tinfo.h, but not quite
  371.     kosher enough to satisfy the compiler we know what we are doing.
  372.     If it bothers you, or something breaks, remove #define CURSES_MACROS
  373.     from u386mon's config.h.
  374.  
  375. 3b. If you get undefined externs for is_linetouched and is_wintouched(),
  376.     you can try editing config.h and #define NO_ISTOUCH.  Good luck -
  377.     these are hack attempts and I have no idea if they will work.
  378.  
  379. 4.  You must run make install as root since u386mon must be setuid to
  380.     'mem' ('sys' for ISC) and nlsym must produce /unix.nlsym.
  381.     For S5R3.1 systems, all bets on "make install" are off.  I don't
  382.     know what it takes, it'll vary from system to system, and the
  383.     Make.sVr31 is only a guide.  For instance, you may want to
  384.     rename the program to u68kmon on 68000 systems :-).
  385.  
  386.     If you are a user of old u386mon versions, run the new nlsym since
  387.     the older /unix.nlsym format is not compatible with this version.
  388.  
  389. 5.  Sources are in 4-spaced tab format (please don't flame :->).
  390.  
  391. 6.  You'll need to check out config.h and your /usr/include/sys/proc.h.
  392.     If you find a p_sid element in the proc structure, then emable
  393.     #define HAVE_P_SID in config.h so that processes running under job
  394.     control will have their control ttys displayed properly.  (I
  395.     take another slim opportunity to damn POSIX.  "I damn thee.")
  396.     Thanks for the tip to rw@namu01.gwdg.de (Rainer Wittmann STAT).
  397.  
  398. 7.  usage: u386mon [-l] [-p | -P]
  399.     -l lock process into memory (if root)
  400.     -p begin with short ps display
  401.     -P begin with long ps display (if 43 line screen)
  402.     -w begin with disk (winchester) stats [SCO and S5R3.1 only]
  403.     -n begin with STREAMS (net) stats [SCO and S5R3.1 only]
  404.  
  405. 8.  If you are running SCO and get 4 as the size of most or all processes,
  406.     try adding -DUSIZE_FIXED.  SCO 3.2.0 had this info in the struct
  407.     user fields u_tsize, u_dsize, u_ssize wrong, IMHO, and fixed it
  408.     in ODT/3.2.1.  See det_proc.c for more detail.  Your port
  409.     may/WILL vary.
  410.  
  411. 9.  The renice program by Ford Ditto, from which the kmem routines
  412.     came, has been reworked and in included with this release.
  413.     It needs a current /unix.nlsym.
  414.  
  415.     usage: renice -# pid     decrease nice by #
  416.            renice +# pid     increase nice by #
  417.            renice =# pid     set nice to #
  418.  
  419.     The traditional privileges for root and non-root are supported.
  420.  
  421. 10. The libpanel.c module is not an efficient replacement for the
  422.     SVR3.2 panel facility.  It is, however, fully featured and serves
  423.     the needs of u386mon, assisting a port to SVR3.1.  It seems
  424.     efficient enough to use in lieu of native (vendor-supplied)
  425.     panels.
  426.  
  427. Comments are appreciated, especially bug fixes and information
  428. helping to port the program to another 386 SVR3 system.
  429. Somebody was purported to be working on a XENIX/386 lookalike.
  430.  
  431. NO FSF, LPF, FOO or LSD -- just free.
  432.  
  433. {gatech,emory}!n4hgf!wht -or- wht@n4hgf.Mt-Park.GA.US
  434.  
  435. Thanks for various reasons to (alpha order):
  436.  
  437.  
  438. aaron@odt.icom.com
  439. alan@cms2
  440. allbery@ncoast.org
  441. andy@rbdc
  442. annie@axis-design.axis-design.fr (Annie Tanguy)
  443. bel@trout.nosc.mil
  444. bobti@sco.com
  445. davidg@aegis.or.jp
  446. davidgu@sco.com
  447. davis@csrg2.ee.iastate.edu (Jim Davis)
  448. dionj@sco.com (Dion Johnson)  [triple plus thanks!!]
  449. dug@kd4nc
  450. dynsim1.litwin.com!avg (Anil Gokhale)
  451. eao@mvucl.att.com
  452. elsn4000@w107zrz.zrz.tu-berlin.dbp.de
  453. focsys!larry
  454. fredj@wang.com (Fred Jewell)
  455. howardl@wb3ffv.ampr.org
  456. jdc@dell.com (Jeremy Chatfield)
  457. jdm1@eds1.eds.com (Jonathan D. McCown)
  458. jennen@aball.in-berlin.de (Andreas Jennen)
  459. jimmy@denwa.info.com (Jim Gottlieb)
  460. jonl@sco.com
  461. jpradley.jpr.com!root (J-P Radley )
  462. kariy@vataks71.vat-vai.valmet.com
  463. kent@sparky.IMD.Sterling.COM (Kent Landfield)
  464. larry@focsys
  465. lele@idea.sublink.org
  466. marlor@cup.portal.com
  467. martin@hppcmart.grenoble.hp.com
  468. mpd@anomaly.sbs.com
  469. nba@sysware.dk
  470. pat@rwing (Pat Myrto)
  471. petej@ssg2.pharmacia.com (Peter M. Jansson)
  472. peter@radig.de
  473. pgd@bbt.se
  474. randy@chinet.chi.il
  475. rexago8!hc05 (Beirne Konarski)
  476. robertt@sco.com
  477. root@candle.uucp (Bruce Momjian)
  478. root@dinosaur.lonestar.org
  479. rtf.bt.co.uk!traub
  480. rw@namu01.gwdg.de (Rainer Wittmann STAT)
  481. soward@ms.uky.edu
  482. ssb@cs.umn.edu!quest
  483. steen@kiku.dk
  484. steen@kiku.dk (Steen Hammerum)
  485. stevea@i88.isc.com (Steve Alexander)
  486. sunriv!johnc
  487. sysware.sysware.dk!nba (Niels Baggesen)
  488. tore@kiku.dk
  489. trb@ima.ima.isc.com (Andrew Tannenbaum)
  490. wgs6386!budp
  491. xenicon!steveh
  492.